

## Memory Re-cap

**CS1022 – Introduction to Computing II** 

Dr Jonathan Dukes / jdukes@scss.tcd.ie School of Computer Science and Statistics



Byte, half-word and word at address 0xA0000D8

LDR r0, =0xA00000D8

LDRB r1, [r0]

LDR r0, =0xA00000D8

LDRH r1, [r0]

LDR r0, =0xA00000D8

LDR r1, [r0]



ARM7TDMI expects all memory accesses to be aligned

## Examples:

## Address Examples

| Word aligned          | 0x0000000, 0x00001008, 0xA100000C |
|-----------------------|-----------------------------------|
| Not word aligned      | 0x0000001, 0x00001006, 0xA100000F |
| Half-word aligned     | 0x0000000, 0x00001002, 0xA100000A |
| Not half-word aligned | 0x0000003, 0x00001001, 0xA100000B |

See ARM Architecture Reference Manual Section A2.8

Unaligned accesses are permitted but the result is unlikely to be what was intended

Unaligned accesses are supported by later ARM architecture versions

**Little-endian** byte ordering – least-significant byte of word or half-word stored at lower address in memory

**Big-endian** byte ordering – most-significant byte of word or half-word stored at lower address in memory



**Sign extension** performed when loading signed bytes or half-words to facilitate correct subsequent 32-bit signed arithmetic



